// pages/home/home.js
import { getUserChannels } from '../../api/user'
import { getArticles } from '../../api/articles'
Page({

    /**
     * 页面的初始数据
     */
    data: {
        active: 0,
        channels:[],
        articlesData: {
            channel_id: 0,
            timestamp: Date.now(),
            with_top: 1
        },
        articles: [],
        refresher: false,
        isLoading: false
    },

    // 获取用户频道列表
    async initUserChannels() {
        const {data} = await getUserChannels()
        this.setData({
            channels: data.channels
        })
    },

    // 获取频道新闻
    async initArticles() {
        this.setData({
            isLoading: true
        })
        const {data} = await getArticles(this.data.articlesData)
        this.setData({
            articles: [...this.data.articles, ...data.results]
        })
        this.setData({
            isLoading: false
        })
    },

    // 去文章详情页面
    goDetail(e) {
        const id = e.currentTarget.dataset.id
        wx.navigateTo({
            url: '/pages/detail/detail?id=' + id
        })
    },

    onChange(e) {
        this.setData({
            articles:[],
            articlesData: {
                channel_id: e.detail.name,
                timestamp: Date.now(),
                with_top: 1
            }
        })
        this.initArticles()
    },

    // 自定义下拉刷新时触发
    async onPulling() {
        this.setData({
            articles: [],
            'articlesData.timestamp': Date.now()
        })
        await this.initArticles()
        this.setData({
            refresher: false
        })
    },

    // 上拉触底
    onBottom() {
        if (this.data.isLoading) return
        this.setData({
            'articlesData.timestamp': Date.now()
        })
        this.initArticles()
    },

    /**
     * 生命周期函数--监听页面加载
     */
    async onLoad(options) {
        await this.initUserChannels()
        this.initArticles()
        this.selectComponent('#tabs').resize();
        
    },

    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady() {
    },

    /**
     * 生命周期函数--监听页面显示
     */
    onShow() {

    },

    /**
     * 生命周期函数--监听页面隐藏
     */
    onHide() {

    },

    /**
     * 生命周期函数--监听页面卸载
     */
    onUnload() {

    },

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh() {

    },

    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom() {
        // this.initArticles()
    },

    /**
     * 用户点击右上角分享
     */
    onShareAppMessage() {

    }
})